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METHOD AND APPARATUS FOR PERFORMING 
FIELD DIAGNOSTICS ON A COMPUTER SYSTEM 

FIELD OF THE INVENTION 
5 The present invention relates to the field of computer systems. More specifically, 

the present invention relates to a method and apparatus for performing field diagnostics on 
a computer system. 

BACKGROUND OF THE INVENTION 

10 Diagnostic software such as AMIDiag by American Megatrends, Inc. and QAPlus® 

by DiagSoft, Inc. provide trouble shooting capabilities for diagnosing problems with server 
computer systems. AMIDiag and QAPlus perform tests on the server computer systems' 
memory, CPU, video controller, serial ports, parallel ports, disks, modems chipsets, and 
other components on the server computer systems. 

15 Typically, when a server computer system experiences problems, a service 

technician is dispatched to the site of the server computer system to perform diagnostics on 
the server computer system. Typically, the service technician is required to reset the server 
computer system and load a diagnostic environment onto the computer system server. The 
service technician may then run a diagnostic program such as AMIDiag, QAPlus, or other 

20 diagnostic program in order to determine the source of the problem. Upon determining the 
source of the problem, the service technician may be required to obtain a piece of hardware 
or a software program to repair the server computer system. Thus, the service technician 
may be required to make more than one visit to the site of the server computer system. The 
drawback with this approach is that additional delay and costs are incurred when a service 

25 technician is required to make multiple visits to the remote location to diagnose and repair 
the server computer system. Similar problems also exist when desktop computer systems, 
main frame computer systems, or other computer systems require diagnosis and repair. 

EM335898406US 
042390.P5358 



.-2.. 



SUMMARY OF THE INVENTION 

A method for managing a computer system is disclosed. A reset of the computer 
system is initiated from a remote location. Diagnostic software downloaded from the 
remote location is run on the computer system. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example and not by way of limitation 
in the figures of the accompanying drawings, in which the like references indicate similar 
elements in and in which: 
5 Figure 1 illustrates a computer system and a remote management console according 

to an embodunent of the present invention; 

Figure 2 illustrates a block diagram of a computer system implementing an 
embodiment of the present invention; 

Figure 3 is a block diagram illustrating the Basic Input Output System (BIOS) 
10 according to an embodiment of the present invention; 

Figure 4 is a block diagram illustrating a console diagnostic tester according to an 
embodiment of the present invention; 

Figure 5 is a block diagram illustrating a system diagnostic tester according to an 
embodiment of the present invention; 
15 Figure 6 is a flow chart illustrating a method for managing a computer system 

according to a first embodiment of the present invention; and 

Figure 7 is a flow chart illustrating a method for managing a computer system 
according to a second embodiment of the present invention. 
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DETAILED DESCRIPTION 

Figure 1 illustrates a computer system 1 10 and a remote management console 120 
according to an embodiment of the present invention. The computer system 1 10 may be a 
server computer system, a desktop or a laptop personal computer (PC), a main frame 
5 computer system, or other computer system. The remote management console 120 resides 
in a location that is remote with respect to the computer system 1 10. The remote 
management console 120 may be a server computer system, a desktop or laptop PC, a main 
frame computer system, or other computer system. The remote management console 120 
is coupled to the computer system 1 10 via a transmission medium 1 30. The computer 

10 system 1 10 and the remote management console 120 transmit data to each other via the 
transmission medium 130. The transmission medium 130 may be fiber optics, cable, 
twisted pair, microwave, or other transmission media. The computer system 1 10 and the 
remote computer system 120 may be coupled to the transmission medium 130 via a 
Ethernet connection, a serial connection, a modem connection, or other connection. 

15 According to an embodiment of the present invention, the remote management 

console 120 is used to perform diagnostics on the computer system 1 10. The remote 
management console 120 initiates a remote connection with the computer system 1 10 via 
the transmission medium 130. The remote connection may be supported by the computer 
system 1 10 via a management module 111. The management module 1 1 1 may be, for 

20 example, an INTEL Server Monitor Module (SMM). The management module 111 

includes a secondary processor (not shown) and a conraiunications interface (not shown) 
that may be used to interface a remote computer system such as the remote management 
console 120 without the assistance of other components in the computer system 1 10. The 
management module 1 1 1 may be used to provide support for the computer system 1 10 

25 when components in or around the computer system 1 10 experience failure. For example, 
the management module 1 1 1 may support out of band access for use when the operating 
system is not functional or when a network connected to a network controller on the 
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computer system 1 10 is down, remote control of the operating system, system shutdown, 
and access to system state information to aid in problem diagnosis. According to an 
embodiment of the present invention, the management module 1 1 1 may be used to connect 
to the remote management console 120 via an Ethernet connection, modem connection, or 
5 other connection. The remote management console 120 may initiate a connection with the 
computer system 1 10 via a serial interface 1 12. The serial interface 1 12 may be used as a 
communications interface to directly connect the remote management console 120 with the 
computer system 1 10 or indirecdy connect the remote management console 120 with the 
computer system 1 10 via a modem (not shown). 

10 The remote management console 120 sends a signal to a shutdown agent on the 

computer system 1 10 to initiate a shutdown and reset of the computer system 1 10. By 
resetting the computer system 1 10, the computer system will execute its Basic Input Output 
System (BIOS) code. The BIOS code includes a boot strap loader. When executed, the 
boot strap loader puts the computer system 1 10 in a diagnostic state. The boot strap loader 

15 recognizes when a connection from the remote management console 120 has been 

established. The boot strap loader may be used to authorize a diagnostic session request 
from the remote management console 120, provide the remote management console 120 
with information about the computer system 1 10, and provide support in downloading 
diagnostic software code from the remote management console 120 directly into a memory 

20 in the computer system 1 10. The diagnostic software code may be executed by a processor 
(not shown) in the computer system 1 10 to generate a diagnostic report of the condition of 
the computer system 1 10 to the remote management console 120. 

Figure 2 illustrates a block diagram of a computer system 200 that may be 
implemented as the computer system 110 (shown in Figure 1) or the remote management 

25 console 120 (shown in Figure 1). The computer system 200 includes a processor 201 that 
processes data signals. The processor 201 may be a complex instruction set computer 
(CISC) microprocessor, a reduced instruction set computing (RISC) microprocessor, a 
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very long instruction word (VLIW) microprocessor, a processor implementing a 
combination of instruction sets, or other processor device. Figure 2 shows an example of 
the present invention implemented on a single processor computer system 200. However, 
it is understood that the present invention may be implemented in a computer system having 
5 multiple processors. The processor 201 is coupled to a CPU bus 210 that transmits data 
signals between processor 201 and other components in the computer system 200. 

The computer system 200 includes a memory 213. The memory 213 may be a 
dynamic random access memory (DRAM) device, a static random access memory (SRAM) 
device, or other memory device. The memory 213 may store instructions and code 

10 represented by data signals that may be executed by the processor 201 . A cache memory 
202 may reside inside the processor 201 to store data signals stored in the memory 213. 
The cache 202 speeds up memory accesses by the processor 201 by taking advantage of its 
locality of access. In an alternate embodiment of the computer system 200, the cache 202 
resides external to the processor 201. 

15 A bridge memory controller 211 may be coupled to the CPU bus 210 and the 

memory 213. The bridge memory controller 21 1 directs data signals between the processor 
201, the memory 213, and other components in the computer system 200 and bridges the 
data signals between the CPU bus 210, the memory 213, and a first I/O bus 220. 

The first I/O bus 220 may be a single bus or a combination of multiple buses. As 

20 an example, the first I/O bus 220 may comprise a Peripheral Component Interconnect (PCI) 
bus, a Personal Computer Memory Card International Association (PCMCIA) bus, a 
NuBus, or other buses. The first I/O bus 220 provides communication links between 
components in the computer system 200. A network controller 221 may be coupled to the 
first I/O bus 220. The network controller 221 links the computer system 200 to a network 

25 of computers (not shown in Figure 2) and supports communication among the machines. 
A display device controller 222 may be coupled to the first I/O bus 220. The display device 
controller 222 allows coupling of a display device to the computer system 200 and acts as 
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an interface between the display device and the computer system 200. The display device 
controller may be a monochrome display adapter (MDA) card, a color graphics adapter 
(CGA) card, an enhanced graphics adapter (EGA) card, an extended graphics array (XGA) 
card or other display device controller. The display device may be a television set, a 
5 computer monitor, a flat panel display or other display device. The display device receives 
data signals from the processor 201 through the display device controller 222 and displays 
the information and data signals to the user of the computer system 200. A video camera 
223 may be coupled to the first I/O bus 220. The video camera 220 operates to capture an 
image of an object. The video camera 223 may be a digital video camera having intemal 

10 digital video capture hardware that translates the captured image into digital graphical data. 
The video camera 223 may be an analog video camera having digital video capture 
hardware external to the video camera 223 for digitizing the captured image. 

A management module 1 1 1 may be coupled to the first I/O bus 220 in an 
embodiment of the computer system 200 where the computer system 200 is implemented as 

15 the computer system 1 10. The management module 1 1 1 includes a secondary processor 
225 that may be used by the remote management console 120 (shown in Figure 1) as a 
shutdown agent. The management module 1 1 1 includes a communications interface 226 
that may be used to interface the remote management console 120 without the assistance of 
other components in the computer system 200. 

20 A second I/O bus 230 may be a single bus or a combination of multiple buses. As 

an example, the second I/O bus 230 may comprise a PCI bus, a PCMCIA bus, a NuBus, 
an Industry Standard Architecture (ISA) bus, or other buses. The second I/O bus 230 
provides communication links between components in the computer system 200. A data 
storage device 23 1 may be coupled to the second I/O bus 230. The data storage device 23 1 

25 may be a hard disk drive, a floppy disk drive, a CD-ROM device, a flash memory device or 
other mass storage device. 
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A read only memory (ROM) 232 may be coupled to the second I/O bus. The ROM 
232 is nonvolatile memory that stores data that is executed by the processor 201. The 
ROM 232 may be used to store the computer system's BIOS. A BIOS provides the 
computer system with a basic set of instructions to perform during system boot up. The 
5 instructions may include tests as well as directions required to control peripherals on the 
computer system. 

A serial interface 1 12 may be coupled to the second I/O bus 230 in an embodiment 
of the computer system 200 where the computer system 200 is implemented as the 
computer system 1 10. The serial interface 1 12 may be used as a general-purpose interface 

10 to connect devices including modems, mice, and printers. According to an embodiment of 
the present invention, the serial interface 1 12 may be used as a communications interface to 
directly connect the remote management console 120 with the computer system 200. 
According to an alternate embodiment of the present invention, the serial interface 1 12 may 
be used as a conmmunications interface to connect the remote management console 120 with 

15 the computer system 200 via a modem (not shown). A secondary processor (not shown) 
may be connected between the secondary I/O bus 230 and the serial interface 1 12 to 
support the serial interface 1 12. The secondary processor may be used by the remote 
management console 120 as a shutdown agent. 

A keyboard interface 233 may be coupled to the second I/O bus 230. The keyboard 

20 interface 233 may be a keyboard controller or other keyboard interface. The keyboard 
interface 233 may be a dedicated device or can reside in another device such as a bus 
controller or other controller. The keyboard interface 233 allows coupling of a keyboard to 
the computer system 200 and transmits data signals from a keyboard to the computer 
system 200. An audio controller 234 may be coupled to the second I/O bus 230. The 

25 audio controller 234 operates to coordinate the recording and playing of sounds is also 
coupled to the I/O bus 230. A bus bridge 224 couples the first I/O bus 220 to the second 
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I/O bus 230. The bus bridge 224 operates to buffer and bridge data signals between the 
first I/O bus 220 and the second I/O bus 230. 

Figure 3 is a block diagram illustrating the BIOS 300 stored in the ROM 232 
(shown in Figure 2) of computer system 1 10 according to an embodiment of the present 
5 invention. The BIOS 300 includes a sequence of instructions that are executed by the 

processor 201 (shown in Figure 2) to perform a system boot sequence when the computer 
system 1 10 is turned on. The sequence of instructions are illustrated as modules in Figure 
3. The BIOS 300 includes an initialization module 310. The initialization module 310 may 
include a power-on self test (POST). The POST is a diagnostic program that performs a 

10 cursory check on the components in the computer system 1 10. The initialization module 
3 10 may also include programs that initialize peripherals in the computer system 1 10, that 
determine the identity of the components on the computer system 110, and that perform 
tests on specific components in the computer system 1 10. The initialization module 3 10 
generates an initialization report that describes the results of the tests performed on the 

15 computer system 1 10. 

The BIOS 300 includes a boot strap loader module 320 that is executed after the 
initialization module 310 is executed. The boot strap loader module 320 includes a 
communications driver 321. The communications driver 321 supports a protocol of 
communications with the management module 1 1 1 (shown in Figures 1 and 2) or the serial 

20 interface 1 12 (shown in Figures 1 and 2). The comimunications driver 321 supports a 

protocol of communications with the management module 1 1 1 where data is passed to each 
other via a shared portion of a memory such as the memory 213 (shown in Figure 2) in the 
computer system 1 10 or other memory. The communications driver 321 may include a 
serial port driver that supports communications with the serial interface 112. 

25 The boot strap loader module 320 includes a session manager 322. The session 

manager 322 determines whether the remote management console 120 is requesting a 
diagnostic session with the computer system 110. According to an embodiment of the 
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present invention, the session manager 322 transmits a query message to the remote 
computer system 120 via a communications interface 226 (shown in Figure 2) on the 
management module 1 1 1 or the serial interface 1 12. The session manager 322 monitors the 
communications interface 226 on the management module 1 1 1 or the serial interface 1 12 
5 for a diagnostic session request message from the remote management console 120 in 
response to the query message. 

The boot strap loader module 320 includes a session authorizer 323. The session 
authorizer 323 determines whether the remote management console 120 is authorized to 
request the diagnostic session. According to an embodiment of the present invention, the 

10 remote management console 120 transmits a diagnostic session password with a diagnostic 
session request message. The session authorizer 323 compares the diagnostic session 
password received with a stored password to determine whether the remote management 
console 120 has authorization to request the diagnostic session. If the remote management 
console 120 has authorization to request the diagnostic session, the session authorizer 323 

15 generates a message stating that a diagnostic session was established successfully. If the 
remote management console 120 does not have authorizadon to request the diagnostic 
session, the session authorizer 323 generates an error message. It should be appreciated 
that the session authorizer 323 may reside in the management module 225 instead of the 
boot strap loader 320. 

20 The boot strap loader module 324 includes a system status provider 324, The 

system status provider 324 provides the remote management console 120 with information 
about the computer system 1 10 to allow the remote management console 120 to determine 
appropriate diagnostics to download onto the computer system 1 10. The system status 
provider 324 may provide the remote management console 120 with information about the 

25 version of the BIOS 300 in the computer system 1 10, an initiahzation report that describes 
the results of the tests performed by the initialization module 3 10, or other information. It 
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should be appreciated that the system status provider may reside in the management module 
225 instead of the boot strap loader 320. 

The boot strap loader module 320 includes a data handler 325. During a diagnostic 
session, the data handler 325 receives data from the remote management console 120. The 
5 data includes diagnostic software code and a location in die memory 213 to write the 
diagnostic software code. The data handler 325 writes diagnostic software code received 
into locations in memory as specified by the remote management console 120. A 
diagnostic environment loader program may be downloaded by the data handler 325 in a 
situation where a two stage loading process is required. In a two stage loading process, the 

10 data handler 325 downloads the diagnostic environment loader which takes control of the 
downloading. The diagnostic environment loader may include functionalities which allows 
it to support more complicated loading operations not supported by the data handler 325. 

The BIOS includes an operating system boot module 330. The operating system 
boot module 330 is executed when the session manager 322 determines that no diagnostic 

15 session requests are being made. The operating system boot module 330 loads an 

operating system into the memory 213 of the computer system 1 10 and runs the operating 
system. 

According to an embodiment of the present invention, the remote management 
console 120 (shown in Figure 1) is used to perform field diagnostics on the computer 

20 system 110. According to one embodiment, performing field diagnostics on the computer 
system 1 10 is performed by the remote management console 120 in response to the 
processor 201 (shown in Figure 2) executing sequences of instructions in main memory 
213 (shown in Figure 2). Such instructions may be read into memory 213 from anotiier 
computer-readable medium, such as data storage device 231 (shown in Figure 2), or from 

25 another source via the network controller 221 (shown in Figure 2). Execution of the 
sequences of instructions causes the processor 201 to perform field diagnostics on the 
computer system 1 10, as will be described hereafter. In an alternative embodiment, 
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hardwired circuitry may be used in place of or in combination with software instructions to 
implement the present invention. Thus, the present invention is not limited to any specific 
combination of hardware circuitry and software. 

Figure 4 is a block diagram of modules implementing a console diagnostic tester 

5 400 according to an embodiment of the present invention. In a preferred embodiment of 
the present invention, the modules are implemented by software and reside in main memory 
213 (shown in Figure 2) of the remote management console 120 as sequences of 
instructions. It should be appreciated that the modules may also be implemented by 
hardware as components coupled to the bus 220 (shown in Figure 2) of the remote 

10 management console 120 (shown in Figure 1) or a combination of both hardware and 
software. 

The console diagnostic tester 400 includes a connection initiator 410. The 
connection initiator 410 establishes a connection between the remote management console 
120 with the computer system 1 10. The connection initiator 410 also generates a signal to 

15 a shutdown agent on the computer system 1 10 to initiate a shutdown and reset of the 
computer system 1 10. Resetting the computer system 1 10 executes the bootstrap loader 
320 (shown in Figure 3) in the BIOS 300 (shown in Figure 3) which places the computer 
system 1 10 in a diagnostic state. The console diagnostic tester 400 includes a session 
initiator 420. Upon receiving a query message from the computer system 1 10, the console 

20 diagnostic tester 400 transmits a diagnostic session request message to the computer system 
1 10. The session initiator 420 may also transmit a diagnostic session password with the 
diagnostic request message. The diagnostic session password may be used by the 
computer system 110 to confirm that the remote management console 120 has authorization 
to request the diagnostic session. The console diagnostic tester 400 includes a system 

25 interrogator 430. Upon receiving a message ft-om the computer system 1 10 that indicates a 
diagnostic session has been established successfully, the system interrogator 430 
interrogates the computer system 1 10 for information to determine types of diagnostics to 
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download to the computer system 1 10. The system interrogator 430 may request for 
example a version of the BIOS on the computer system 1 10, an initialization report 
generated by the BIOS of the computer system 1 10, or other information. The console 
diagnostic tester 400 includes a data loader 440. The data loader 440 downloads data to the 

5 computer system 1 10. The data loader 440 downloads data that includes diagnostic 
software code and locations in memory to write the diagnostic software code. The 
diagnostic software code may include a diagnostic environment loader to assist in 
downloading additional data, a test run time environment, a test control agent, and 
diagnostic tests. The console diagnostic tester 400 includes an execution unit 450 that runs 

10 the diagnostic softwaie downloaded on the computer system 1 10. 

According to an embodiment of the present invention, the computer system 1 10 is 
used by the remote management console 120 to perform field diagnostics on the computer 
system 1 10. According to one embodiment, field diagnostics is performed on the computer 
system 1 10 in response to the processor 201 (shown in Figure 2) executing sequences of 

15 instructions in main memory 213 (shown in Figure 2). Such instructions may be read into 
memory 213 from another computer-readable medium, such as data storage device 231 
(shown in Figure 2), or from another source via the network controller 221 (shown in 
Figure 2). Execution of the sequences of instructions causes the processor 201 to perform 
diagnostics on the computer system 1 10, as will be described hereafter. In an alternative 

20 embodiment, hardwired circuitry may be used in place of or in combination with software 
instructions to implement the present invention. Thus, the present invention is not limited 
to any specific combination of hardware circuitry and software. 

Figure 5 is a block diagram of modules implementing a system diagnostic tester 500 
according to an embodiment of the present invention. In a preferred embodiment of the 

25 present invention, the modules are implemented by software and reside in main memory 
213 (shown in Figure 2) of the computer system 1 10 as sequences of instructions. It 
should be appreciated that the modules may also be implemented by hardware as 
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components coupled to the bus 220 (shown in Figure 2) or a combination of both hardware 
and software. 

The system diagnostic tester 500 includes a diagnostic environment loader 510. 
The diagnostic environment loader 510 may be used to support a two stage loading process 

5 where it performs loading operations which a data handler may not support. It should be 
appreciated that the system diagnostic tester 500 may operate without the diagnostic 
environment loader 510. The system diagnostic tester 500 includes a test run time 
environment 520. The test run time environment 520 is a system environment that allows 
code to be executed. The test run time environment may be for example a Disk Operating 

10 System (DOS) or other operating system. The system diagnostic tester 500 includes a test 
control agent 530. The test control agent 530 is an application running in the test run time 
environment 520 that operates as a mechanism for the remote computer system 120 (shown 
in Figure 1) to determine which diagnostic tests to execute and obtain the results of the 
diagnostic tests. The test control agent 530 allows the remote management console 120 to 

15 manages diagnostic testing on the computer system 1 10. The system diagnostic tester 500 
also includes diagnostic tests 540 that have been downloaded from the remote management 
console. 

The present invention allows the remote downloading and execution of diagnostic 
test programs 540 onto the computer system 1 10 without any local user intervention. The 

20 present invention does not require a peripheral drive such as a hard drive, floppy drive, or 
CDROM drive to be functional on the computer system 1 10 to support the diagnostic 
session. The test run time environment 520 and diagnostic tests 540 are downloaded to 
memory 213 rather than run from the computer system peripheral disk drive. 

Figure 6 is a flow chart illustrating a method for managing a computer system 

25 according to a first embodiment of the present invention. At step 601 , the computer system 
is reset from a remote location. According to an embodiment of the present invention, 
resetting the computer system from a remote location is achieved by interfacing the 
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computer system via a remote connection and sending a shutdown request to a shutdown 
agent in the computer system via the remote connection. Interfacing the computer system 
via a remote connection may be achieved, for example, by interfacing the computer system 
via an Ethernet connection or a modem connection to a management module connected to 

5 the computer system, or interfacing the computer system via a direct connection or modem 
connection to a serial interface connected to the computer system. 

At step 602, a diagnostic session request and a diagnostic session password is 
transmitted to the computer system via the remote connection. 

At step 603, the computer system is interrogated to determine types of diagnostic 

10 software to download onto the computer system. According to an embodiment of the 
present invention, the computer system is interrogated by retrieving BIOS version 
information, an initialization report, or other information from the computer system. 
Determining types of diagnostic software to download onto the computer system may be 
achieved by matching a set of diagnostic tests designed for a specific BIOS version or 

15 selecting specific diagnostic tests to run on a component reported as failing a test in the 
initialization report. 

At step 604, data is downloaded onto the computer system. According to an 
embodiment of the present invention, the data includes diagnostic software code and a 
location in memory to write the diagnostic software code. The diagnostic software code 

20 may include a diagnostic environment loader, test run time environment, test control agent, 
tests, or other diagnostic software code. 

At step 605, the diagnostic software downloaded from the remote location is 
executed. 

At step 606, a diagnostic report generated from the diagnostic software is 
25 transmitted to the remote location. 

Figure 7 is a flow chart illustrating a method for managing a computer system 
according to a second embodiment of the present invention. At step 701, it is determined 
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whether a remote computer system is requesting a diagnostic session. If the remote 
computer system is not requesting a diagnostic session, control proceeds to step 702. If 
the remote computer system is requesting a diagnostic session, control proceeds to step 
703. According to an embodiment of the present invention, determining whether a remote 

5 computer system is requesting a diagnostic session is achieved by transmitting a query 

message to the remote computer system via a communications interface, and monitoring the 
communications interface for a diagnostic session request message from the remote 
computer system. 

At step 702, the operating system is booted up. 

10 At step 703, it is determined whether the remote computer system is authorized to 

participate in the diagnostic session. If the remote computer system is not authorized to 
participate in the diagnostic session, control proceeds to step 704. If the remote computer 
system is authorized to participate in the diagnostic session, control proceeds to step 705. 
At step 704, a error message is transmitted to the remote computer system. 

15 At step 705, system status information is transmitted to the remote computer 

system. The system status information may include a BIOS version number, an 
initialization report, or other information. The system status information may be used by 
the remote computer system to determine the types of diagnostics to perform on the 
computer system. 

20 At step 706, diagnostic software code received from the remote computer system is 

written into locations in memory as specified by the remote computer system. 
At step 707, the diagnostic software is executed. 

In the foregoing description, the invention is described with reference to specific 
exemplary embodiments thereof. It will, however, be evident that various modifications 
25 and changes may be made thereto without departing from the broader spirit and scope of 
the present invention as set forth in the appended claims. The specification and drawings 
are to be regarded in an illustrative rather than a restrictive sense. 
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CLAIMS 
In the claims: 



1 1 . A method for managing a computer system, comprising: y 

2 initiating a reset of the computer system from a remote location; and 

3 running diagnostic software on the computer system downloaded from the remote 

4 location. 

1 2 . The method of Claim 1 , wherein initiating the reset of the computer system 

2 from the remote location, comprises: 

3 interfacing the computer system via a remote connection; and 

4 sending a request to a shut down agent in the computer system via the remote 

5 connection. 

1 3 . The method of Claim 1 , further comprising the step of interrogating the 

2 computer system to determine types of diagnostic software to download onto the computer 

3 system. 

1 4 . The method of Claim 3, wherein interrogating the computer system 

2 comprises retrieving BIOS information from the computer system. 

1 5 . The method of Claim 1 , further comprising the step of downloading 

2 diagnostic software onto the computer system. 

1 6 . The method of Claim 5, wherein downloading diagnostic software onto the 

2 computer system comprises transmitting data that includes diagnostic software code and a 

3 location in memory to write the diagnostic software code to a conmiunications driver in the 

4 computer system. 
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1 7 . The method of Claim 2, wherein interfacing the computer system via a 

2 remote connection, comprises interfacing the computer system via an Ethernet connection 

3 to a management module connected to the computer system. 

1 8 . The method of Claim 2, wherein interfacing the computer system via a 

2 remote connection, comprises interfacing the computer system via a modem connection to a 

3 management module connected to the computer system. 

1 9 . The method of Claim 2, wherein interfacing the computer system via a 

2 remote connection, comprises interfacing the computer system via a serial connection to a 

3 serial interface connected to the computer system. 

1 10. The method of Claim 2, wherein interfacing the computer system via a 

2 remote connection, comprises interfacing the computer system via a modem connection to a 

3 serial interface connected to the computer system. 

1 1 1 . A method for managing a computer system, comprising: 

2 determining whether a remote computer system is requesting a diagnostic session; 

3 and 

4 writing diagnostic software code received from the remote computer system into 

5 locations in memory as specified by the remote computer system. 

1 12. The method of Claim 1 1 , wherein determining whether a remote computer 

2 system is requesting a diagnostic^session, comprises: 

3 transmitting a query message to the remote computer system via a communications 

4 interface; and 
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5 monitoring the communications interface for a diagnostic session request message 

6 from the remote computer system. 

1 13. The method of Claim 1 1 , further comprising determining whether the 

2 remote computer system is authorized to participate in the diagnostic session. 

1 14. The method of Claim 1 1 , further comprising executing the diagnostic 

2 software. 

1 1 5 . A computer-readable medium having a sequence of instructions stored 

2 thereon, the sequence of instructions, when executed by a processor, causes the processor 

3 to perform the steps of: 

4 determining whether a remote computer system is requesting a diagnostic session; 

5 and 

6 writing diagnostic software code received from the remote computer system into 

7 locations in memory as specified by the remote computer system. 

1 16. The computer-readable medium of Claim 15, wherein determining whether 

2 a remote computer system is requesting a diagnostic session, comprises: 

3 transmitting a query message to the remote computer system via a communications 

4 interface; and 

5 monitoring the communications interface for a diagnostic session request message 

6 from the remote computer system. 

1 17. The computer-readable medium of Claim 1 5, further comprising 

2 instructions which when executed by the processor causes the processor to determine 

3 whether the remote computer system is authorized to participate in a diagnostic session. 
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1 18. The computer-readable medium of Claiin 1 5 , wherein the computer-readable 

2 medium is a read only memory and the sequences of mstructions are in a Basic Input 

3 Output System (BIOS) of a computer system. 

1 1 9 . An apparatus, comprising: 

2 a shutdown agent that resets a computer system in response to receiving a shut 

3 down request from a remote computer system; 

4 a session manager that determines whether the remote computer system is 

5 requesting a diagnostic session; and 

6 a data handler that writes diagnostic software code received from the remote 

7 computer system into locations in memory as specified by the remote computer system. 

1 20. The apparatus of Claim_19, further comprising a session authorizer that 

2 determines whether the remote computer system is authorized to request the diagnostic 

3 session. 

1 21. The apparatus of Claim 19, further comprising a system status provider that 

2 provides the remote computer system with information to determine types of diagnostic 

3 software to download to the computer system. 

1 22. A computer system, comprising: 

2 a bus; 

3 a processor coupled to the bus; 

4 a memory coupled to the bus; 

5 a diagnostic manager, coupled to the bus, that includes a shut down agent that 

6 resets a computer system in response to receiving a shut down request from a remote 
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7 computer system, a session manager that determines whether the remote computer system 

8 is requesting a diagnostic session, and a data handler that writes diagnostic software code 

9 received from the remote computer system into locations in memory as specified by the 
10 remote computer system. 
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ABSTRACT 

A method for managing a computer system includes initiating a reset of the 
computer system from a remote location. Diagnostic software on the computer system is 
downloaded from the remote location. 
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Title 37, Code of Federal Regulations, Section 1 .56 
Duty to Disclose Infonnation Material to Patentability 



(a) A patent by its very nature is affected with a public interest. The public interest is best served, 
and the most effective patent examination occurs when, at the time an application is being examined, the 
Office is aware of and evaluates the teachings of all information material to patentability. Each individual 
associated with the filing and prosecution of a patent application has a duty of candor and good faith in dealing 
with the Office, which includes a duty to disclose to the Office all information known to that individual to be 
material to patentability as defined in this section. The duty to disclosure information exists with respect to 
each pending claim until the claim is cancelled or withdrawn from consideration, or the application becomes 
abandoned. Information material to the patentability of a claim that is cancelled or withdrawn from 
consideration need not be submitted if the information is not material to the patentability of any claim remaining 
under consideration in the application. There is no duty to submit information which is not material to the 
patentability of any existing claim. The duty to disclosure all infomnation known to be material to patentability 
is deemed to be satisfied if all information known to be material to patentability of any claim issued in a patent 
was cited by the Office or submitted to the Office in the manner prescribed by §§1 .97(b)-(d) and 1 .98. 
However, no patent will be granted on an application in connection with which fraud on the Office was practiced 
or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. The Office 
encourages applicants to carefully examine: 

(1) Prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) The closest infonnation over which individuals associated with the filing or prosecution of a 
patent application believe any pending claim patentably defines, to make sure that any material information 
contained therein is disclosed to the Office. 

(b) Under this section, information is material to patentability when it is not cumulative to 
information already of record or being made or record in the application, and 

(1) It establishes, by itself or in combination with other infonnation, a prima facie case of 
unpatentability of a claim; or 

(2) It refutes, or is inconsistent with, a position the applicant takes in: 

(i) Opposing an argument of unpatentability relied on by the Office, or 

(ii) Asserting an argument of patentability. 

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is 
unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim its 
broadest reasonable construction consistent with the specification, and before any consideration is given to 
evidence which may be submitted in an attempt to establish a contrary conclusion of patentability. 

(c) Individuals associated with the filing or prosecution of a patent application within the 
meaning of this section are: 

(1 ) Each inventor named in the application; 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the 
application and who is associated with the inventor, with the assignee or with anyone to whom there is an 
obligation to assign the application. 

(d) Individuals other than the attorney, agent or inventor may comply with this section by 
disclosing information to the attorney, agent, or inventor. 
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